package cn.iocoder.yudao.module.system.dal.mysql.dept;

import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.iocoder.yudao.module.system.controller.admin.dept.vo.dept.DeptListReqVO;
import cn.iocoder.yudao.module.system.dal.dataobject.dept.DeptDO;
import org.apache.ibatis.annotations.Mapper;

import java.util.List;

/**
 * 部门映射器
 *
 * @author huangweidong
 * @date 2023/05/09
 */
@Mapper
public interface DeptMapper extends BaseMapperX<DeptDO> {

    /**
     * 查询列表
     *
     * @param reqVO 请求VO
     * @return {@code List<DeptDO>}
     */
    default List<DeptDO> selectList(DeptListReqVO reqVO) {
        return selectList(new LambdaQueryWrapperX<DeptDO>()
                .likeIfPresent(DeptDO::getName, reqVO.getName())
                .eqIfPresent(DeptDO::getStatus, reqVO.getStatus()));
    }

    /**
     * 查询通过父id和名字
     *
     * @param parentId 父id
     * @param name     名字
     * @return {@code DeptDO}
     */
    default DeptDO selectByParentIdAndName(Long parentId, String name) {
        return selectOne(DeptDO::getParentId, parentId, DeptDO::getName, name);
    }

    /**
     * 查询统计通过父id
     *
     * @param parentId 父id
     * @return {@code Long}
     */
    default Long selectCountByParentId(Long parentId) {
        return selectCount(DeptDO::getParentId, parentId);
    }

}
